## EENG HW 5Report Template

Name: Hari Krishna Gonemadatala(11642136)

## Table of Contents

| Design                  | 3                            |
|-------------------------|------------------------------|
| Block diagrams          | 3                            |
| Overall design          | 3                            |
| Subcomponents           | 6                            |
| Design explanation      | 8                            |
| Functionality           | Error! Bookmark not defined. |
| Design Choices          | Error! Bookmark not defined. |
| Results                 | 9                            |
| Generated Schematic     | 9                            |
| Waveforms               | 12                           |
| Table/Calculations      | 14                           |
| Overall Design          | 14                           |
| Subcomponent test cases | 15                           |
| References              | Error! Bookmark not defined. |

# **Design**

## **Block diagrams**

Overall design



Overall component: top box

Parameters: d\_w - data width (for inputs and outputs)

Input ports:

| Port name                                                                                                                                    | Bit width | Purpose               |
|----------------------------------------------------------------------------------------------------------------------------------------------|-----------|-----------------------|
| A0, A1, A2,A3,<br>B0, B1, B2, B3                                                                                                             | d_w = 4   | Data inputs           |
|                                                                                                                                              |           |                       |
| op0, op1,<br>op2,op3,op4, op5,<br>op6, op7                                                                                                   |           | Selection line for cu |
| MXsel00,mxSel01, MXsel10, mxSel11, MXsel20, mxSel21, MXsel30, mxSel31, MXsel40, mxSel41, MXsel50, mxSel51, MXsel60, mxSel61, MXsel70,mxSel71 | 2         | Mux selection lines   |
| R_en1, R_en2,<br>R_en3, R_en4                                                                                                                | 1         | enable                |

#### Output ports:

| Port name        | Bit width | Purpose     |
|------------------|-----------|-------------|
| 000,001,002,003, | $d_w = 4$ | Data output |
| o10, o11, o12,   |           |             |
| o13              |           |             |

Necessary intermediate signals:

\*If there are no intermediate signals, you can remove this section name and table\*

| Port name                       | Bit       | Purpose              |
|---------------------------------|-----------|----------------------|
|                                 | width     |                      |
| Y00,Y01,Y02,Y03,Y10,Y11,Y12,Y13 | $d_w = 4$ | Intermediate signals |
|                                 |           |                      |
|                                 |           |                      |
|                                 |           |                      |
|                                 |           |                      |

## **Subcomponents**

Mux:



### Input ports:

| Port name | Bit width | Purpose                                                                |
|-----------|-----------|------------------------------------------------------------------------|
| A,b,c,d   | $d_w = 4$ | Data inputs                                                            |
| Sel       | 1         | Select line, selects which of the 2 data inputs to send to data output |

### Output ports:

| Port name | Bit width | Purpose     |
|-----------|-----------|-------------|
| Y         | $d_w = 4$ | Data output |

<sup>\*</sup>Necessary intermediate signals: \*

#### Cu with resistor:



### Input ports:

| Port name      | Bit width | Purpose                                                                |
|----------------|-----------|------------------------------------------------------------------------|
| I0, I1, I2, I3 | $d_w = 4$ | Data inputs                                                            |
| Sel            | 2         | Select line, selects which of the 4 data inputs to send to data output |

## Output ports:

| Port name | Bit width | Purpose     |
|-----------|-----------|-------------|
| y         | $d_w = 4$ | Data output |

## **Design explanation**

It is a 2 by 4 architecture pre configurable

Both inputs and outputs are stored units.

The data flow according to design.

A0, A1, A2, A3, B0, B1, B2, B3 are data inputs.

op0, op1, op2,op3,op4, op5, op6, op7 selections lines for cu.

MXsel00,mxSel01, MXsel10, mxSel11, MXsel20, mxSel21, MXsel30, mxSel31, MXsel40, mxSel41, MXsel50, mxSel51, MXsel60, mxSel61, MXsel70,mxSel71 are mux selection lines.

o00,o01,o02,o03, o10, o11, o12, o13 are out puts

## Results

## **Generated Schematics**







#### Waveforms

|                |       |          |            |            |            |            |            |            |            |            | 1,000.000  |
|----------------|-------|----------|------------|------------|------------|------------|------------|------------|------------|------------|------------|
| ame            |       | 0.000 ns | 100.000 ns | 200.000 ns | 300.000 ns | 400.000 ns | 500.000 ns | 600.000 ns | 700.000 ns | 800.000 ns | 900.000 ns |
| A0[3:0]        | 1001  |          |            |            |            |            | 1001       |            |            |            |            |
| A1[3:0]        | 1000  |          |            |            |            |            | 1000       |            |            |            |            |
| A2[3:0]        | 1011  |          |            |            |            |            | 1011       |            |            |            |            |
| A3[3:0]        | 1010  | (        |            |            |            |            | 1010       |            |            |            |            |
| B0[3:0]        | 0010  | (        |            |            |            |            | 0010       |            |            |            |            |
| B1[3:0]        | 0011  | (        |            |            |            |            | 0011       |            |            |            |            |
| B2[3:0]        | 0010  | (        |            |            |            |            | 0010       |            |            |            |            |
| B3[3:0]        | 0011  | (        |            |            |            |            | 0011       |            |            |            |            |
| oP0[4:0]       | 10011 | (        |            |            |            |            | 10011      |            |            |            |            |
| op1[4:0]       | 10101 | (        |            |            |            |            | 10101      |            |            |            |            |
| op2[4:0]       | 00010 |          |            |            |            |            | 00010      |            |            |            |            |
| op3[4:0]       | 00111 |          |            |            |            |            | 00111      |            |            |            |            |
| op4[4:0]       | 00110 |          |            |            |            |            | 00110      |            |            |            |            |
| op5[4:0]       | 00010 |          |            |            |            |            | 00010      |            |            |            |            |
| op6[4:0]       | 10100 |          |            |            |            |            | 10100      |            |            |            |            |
| op7[4:0]       | 00011 |          |            |            |            |            | 00011      |            |            |            |            |
| MXsel00[1:0]   | 00    |          |            |            |            |            | 00         |            |            |            |            |
| mxSel01[1:0]   | 00    |          |            |            |            |            | 00         |            |            |            |            |
| MXsel10[1:0]   | 01    |          |            |            |            |            | 01         |            |            |            |            |
| mxSel11[1:0]   | 10    |          |            |            |            |            | 10         |            |            |            |            |
| MXsel20[1:0]   | 00    |          |            |            |            |            | 00         |            |            |            |            |
| mxSel21[1:0]   | 00    |          |            |            |            |            | 00         |            |            |            |            |
| MXsel30[1:0]   | 10    |          |            |            |            |            | 10         |            |            |            |            |
| mxSel31[1:0]   | 00    | (        |            |            |            |            | nn         |            |            |            |            |
|                |       |          |            |            |            |            |            |            |            |            |            |
| op7[4:0]       | 00011 |          |            |            |            |            | 00011      |            |            |            |            |
| MXsel00[1:0]   | 00    |          |            |            |            |            | 00         |            |            |            |            |
| mxSel01[1:0]   | 00    |          |            |            |            |            | 00         |            |            |            |            |
| MXsel10[1:0]   | 01    |          |            |            |            |            | 01         |            |            |            |            |
| mxSel11[1:0]   | 10    |          |            |            |            |            | 10         |            |            |            |            |
| MXsel20[1:0]   | 00    |          |            |            |            |            | 00         |            |            |            |            |
| mxSel21[1:0]   | 00    |          |            |            |            |            | 00         |            |            |            |            |
| MXsel30[1:0]   | 10    |          |            |            |            |            | 10         |            |            |            |            |
| mxSel31[1:0]   | 00    |          |            |            |            |            | 00         |            |            |            |            |
| MXsel40[1:0]   | 00    |          |            |            |            |            | 00         |            |            |            |            |
| mxSel41[1:0]   | 00    |          |            |            |            |            | 00         |            |            |            |            |
| MXsel50[1:0]   | 01    |          |            |            |            |            | 01         |            |            |            |            |
| mxSel51[1:0]   | 10    |          |            |            |            |            | 10         |            |            |            |            |
| MXsel60[1:0]   | 10    |          |            |            |            |            | 10         |            |            |            |            |
| mxSel61[1:0]   | 00    |          |            |            |            |            | 00         |            |            |            |            |
| MXsel70[1:0]   | 00    |          |            |            |            |            | 00         |            |            |            |            |
| mxSel71[1:0]   | 00    |          |            |            |            |            | 00         |            |            |            |            |
| clk            | 0     |          |            |            |            |            |            |            |            |            |            |
| R_en1          | 1     |          |            |            |            |            |            |            |            |            |            |
|                | 1     |          |            |            |            |            |            |            |            |            |            |
| R_en2          | 1     |          |            |            |            |            |            |            |            |            |            |
| R_en2<br>R_en3 |       |          |            |            |            |            |            |            |            |            |            |
|                | 1     |          |            |            |            |            |            |            |            |            |            |
| R_en3          |       |          |            |            |            |            | 0100       |            |            |            |            |



#### • Test case 2





#### **Table/Calculations**

## **Overall Design**

My output for test case 1 is taken from cu11 that is

Test Case # (\*0ns to 5ns\*):

| CU# | SourceA | SourceB | А    | В    | Oper | Calculated<br>Op | Simulated Op | Match |
|-----|---------|---------|------|------|------|------------------|--------------|-------|
| CU1 | Α       | В       | 0011 | 0010 | MULT | 0110             | 0110         | Yes   |
| CU2 | С       | D       | 0101 | 0100 | ADD  | 1001             | 1001         | Yes   |
| CU3 | CU1     | CU2     | 0110 | 1001 | LT   | 1111             | 1111         | Yes   |

| ••• |  |  |  |  |
|-----|--|--|--|--|
|     |  |  |  |  |

### Test Case # (\*5ns to 10ns\*):

| CU# | SourceA | SourceB | А    | В    | Oper | Calculated<br>Op | Simulated Op | Match |
|-----|---------|---------|------|------|------|------------------|--------------|-------|
| CU1 | Α       | В       | 0011 | 0010 | MULT | 0110             | 0110         | Yes   |
| CU2 | С       | D       | 0101 | 0100 | ADD  | 1001             | 1001         | Yes   |
| CU3 | CU1     | CU2     | 0110 | 1001 | LT   | 1111             | 1111         | Yes   |
| ••• |         |         |      |      |      |                  |              |       |

## Subcomponent test cases

Test Case # (\*0ns to 5ns\*):

| А    | В    | Oper       | Calculated<br>Op | Simulated Op | Match |
|------|------|------------|------------------|--------------|-------|
| 0011 | 0010 | MULT (000) | 0110             | 0110         | Yes   |
| 0101 | 0100 | ADD (001)  | 1001             | 1001         | Yes   |
| 0110 | 1001 | LT (010)   | 1111             | 1111         | Yes   |
|      |      |            |                  |              |       |

### Test Case # (\*5ns to 10ns\*):

| А    | В    | Oper       | Calculated<br>Op | Simulated Op | Match |
|------|------|------------|------------------|--------------|-------|
| 0011 | 0010 | MULT (000) | 0110             | 0110         | Yes   |
| 0101 | 0100 | ADD (001)  | 1001             | 1001         | Yes   |
| 0110 | 1001 | LT (010)   | 1111             | 1111         | Yes   |
|      |      |            |                  |              |       |